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Inventor: Paul A. LaBerge 

Field of Invention 

[00011 The invention relates to integrated circuits and semiconductor systems, and more 

particularly, to accessing data. 

Background of the Invention 
[0002] Many electronic systems use memory to store information. Memory devices include 

O an interface to communicate with other elements of the system. An ordmary mterface 

?^ provides several inputs and outputs, including various bus connections to accommodate 

J multi-bit transfers in paraUel. In particular, memory devices typically include a command 

T bus and an address bus that transmit command and address information from a controUer to 

fU the memory device. 



tt003] 



For example, many existing DRAM devices include a command/address bus having 
^ three command signals, ordinarUy row address strobe (RAS), column address strobe (CAS), 

and write enable (WE), and several address signals, including row/column address (A[X:0]), 
bank address (BA[1:0]), and chip select (CS). The command signals decode yielding several 
commands, such as ACTIVATE ROW, COLUMN SELECT with WRITE/READ, 
PRECHARGE ROW, PRECHARGE ALL, AUTO REFRESH, SELF REFRESH, WAKE, 
LOAD MODE, and LOAD EXTENDED MODE. 
[0004] Certain access processes saturate the command/address bus, hmiting the 

throughput^andwidth of the memory device. For example, referring to Figure 9 iUustrating 
a simplified memory access process, if the addressing patterns dictate all page misses, each 
burst transfer operation 900 of data to/from the memory devices requires one ACTIVATE 
command 910 for the row address 911 and one READ or WRITE command 912 
corresponding to the column address data 913. Bank selection data is transferred via a bank 

Client Docket 01-0348 1 
Attorney Docket 37829.0700 



EXPRESS MAtt NO. EL609006965US 

selection bus 924. A PRECHARGE command 914 for the selected bank 915 is then asserted 
to close the selected bank. If the burst size does not allow time for three commands, 
however, the data transfer rate is throttled. A common example is a burst size of four data 
bus transfers 916A-D with the data bus 920 running at double the rate of the 
command/address bus 922. This is a simplified, Ulustrative example, for memory accesses 
typically utilize interleaved commands to the various banks to optimize the operation of the 
memory system, but it serves to Ulustrate that each data bus burst transfer operation 900 
provides two command/address slots 910, 912. Because three commands are required to 

\t effect the transfer, however, the data bus efficiency may be reduced to two-thirds of its 

W 

capacity. 

^ Summary of the Invention 

j|do05] An electronic system according to various aspects of the present invention includes a 

C memory having a location-specific command mterface and a general command interface, 

ffi The memory communicates with other components in the system via a main command bus 

configured to transfer address-specific commands and a supplementary command bus 
configured to transfer general commands. Commands may be received by the memory 
simultaneously at the respective interfaces. For example, a PRECHARGE command may be 
received on the general command interface while a memory access is received on the 
location-specific interface. 
Brief Description of the Drawings 
[00061 A more complete understanding of the present invention may be derived by referring 

to the detailed description and claims when considered in connection with the foUowing 
illustrative Figures, which may not be to scale. In the following Figures, like reference 
numbers refer to similar elements throughout the Figures. 
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[0007] Figure 1 is a block diagram of an electronic system according to various aspects of 

the present invention; 

[0008] Figure 2 is a block diagram of a memory interface and a bus system; 

[0009] Figure 3 is a block diagram of a main control bus and a supplementary control bus; 

[0010] Figure 4 is a timing diagram for consecutive memory accesses; 

[001 1] Figure 5 is a block diagram of an alternative embodiment of a main control bus and a 

supplementary control bus; 
gn2] Figure 6 is another alternative embodiment of a main control bus and a 

SI supplementary control bus; 

yj .... 

i^l3] Figure 7 is a timing diagram for providing a secondary command mdicator; 

=P 

^14] Figure 8 is a timing diagram for providing a tertiary command mdicator; and 

^015] Figure 9 is a timing diagram for a simplified, Ulustrative prior art memory access. 

^016] Elements in the figures are illustrated for simplicity and clarity and have not 

I necessarUy been drawn to scale. For example, the dimensions of some of the elements in the 

figures may be exaggerated relative to other elements to help to improve understanding of 

embodiments of the present invention. 

Detailed Description 

[0017] The present invention may be described in terms of functional block components and 

various processing steps. Such functional blocks may be reaUzed by any number of 
hardware and software components configured to perform specified functions. For example, 
the present invention may employ various components, e.g., memory elements, interface 
elements, logic elements, buses, package connections, and the like, which may carry out a 
variety of functions under the control of one or more processors or other control devices. In 
addition, the present invention may be practiced in conjunction with any number of storage 
systems and data transmission media and protocols and the systems described are merely 
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exemplary applications of the invention. Further, the present invention may employ any 
number of conventional techniques for data transmission, signaling, data processing, bus 
control, and the like. 

[0018] Referring to Figure 1, an electronic system 100 according to various aspects of the 

present invention may include a processor 102 and a memory system 104. The present 
electronic system 100 comprises a system using a memory, such as a personal computer 
system. The electronic system 100 may comprise, however, any suitable electronic system, 
such as a communication system, computing system, entertainment system, control system, 
portable electronic device, audio component, appUance, or factory control system, and the 
various components may differ according to the particular system and environment. The 
processor 102 generaUy controls operation of the electronic system 100, and may comprise 
any appropriate processor or controller, such as an Intel, Motorola, or Advanced Micro 
Devices microprocessor. In some appUcations, the processor 102 may be replaced by other 
devices, such as logic circuits or ASICs, or omitted altogether. 

The memory system 104 comprises a storage system for storing data. The memory 
system 104 may comprise any appropriate memory system for storing data and transferring 
data between the memory system 104 and the processor 102 or another component. In the 
present embodiment, the memory system 104 includes one or more memory modules 210A, 
B, a memory controller 212, and a bus system 106. The memory controUer 212 controls 
access to, including data transfers to and from, the memory modules 210, and may perform 
further functions and operations as well. The memory controller 212 may comprise any 
suitable memory controller for controlling access to the memory modules 210. In some 
embodiments, the memory controller 212 may be omitted and/or have its functions 
performed by other system components. 
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The memory modules 210 may comprise any system for storing data, such as a 
ROM, SRAM, DRAM, SDRAM, or any other suitable storage system. In the present 
embodiment, the memory modules 210 comprise double data rate synchronous dynamic 
random access memory (DDR SDRAM) modules from Micron. For example, each memory 
module 210 suitably comprises a high-speed CMOS SDRAM internally configured as four 
banks of DRAMS. The memory modules 210, however, may comprise any appropriate 
memory or configuration, such as an individual memory chip, a multi-component device, or 
another type of storage device altogether. The memory modules 210 interface with the rest 
of the electronic system 100 through any suitable interface, such as a plurality of connections 
comprising pins, solder, conductive connections, optical couplings, or any other suitable 
coupling. 

1)211 The bus system 106 connects the components of the memory system 104. The 

memory system 104, including the bus system 106, may utUize any appropriate signals, 
S including optical or electric signals. The bus system 106 may comprise any suitable medium 

for transferrmg information, such as a plurality of wires, optical fibers, or other 
communication medium. In the present embodiment, the medium comprises an electronic 
bus, such as a serial bus or multi-bit bus, to which the memory system 104 and other 
components may be attached. 
[0022] Communications with the memory system 104 may be controlled in any suitable 

manner and by any suitable component, such as using the processor 102, the memory 
controUer 212, or other circuit or system to control communications. In the present 
embodiment, communications with the memory module 210 are suitably controUed by the 
memory controller 212. 

[0023] The bus 106 and the connected components may communicate using any appropriate 

communication techniques and/or protocols. For example, the components may 
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communicate via the bus 106 using a selected conventional protocol, such as those described 
in specifications for Micron SDRAMs. The bus 106 is also suitably configured to 
communicate with the memory modules 210. For example, referring to Figure 2, each 
memory module 210 includes an interface 250 having a data bus connection 320, address 
bus connection 324, main command bus connection 326, and supplementary command bus 
connection 328. The bus 106 may be configured accordingly to facilitate communication, 
such as including a data bus 220, an address bus 224, a main control bus 226, and a 
p supplementary control bus 228. 

The memory interface 250 and the bus 106 provide one or media for transferring 
I \ information to and from the/emory module 210. Each bus component 220, 224, 226, 228 
ordinarily transfers a seized type of information, i.e., address selection information on the 
H address bus 224, data/n the data bus 220, and command signals on the main control bus 226 

U and the supplenWrtary control bus 228. Further, each bus may be suitably configured to 

transfer the refevant information. For example, each bus may be configured to handle a 
selected number of bits. 

[00251 More particularly, the data bus interface 320 of the present embodiment comprises a 

multibit, such as 4-, 8-, or 16-bit, connection for transferring information to and from the 
data bus 220. The address bus interface 324 of the present embodiment comprises a 13-bit 
connection for, among other things, receiving row and column address mformation to select 
one location out of the memory array 210 in a selected bank. The data bus 220 and address 
bus 224 are suitably configured to interface with the memory module 210 via the 
corresponding interfaces 320, 324. 

[00261 Signals on the mam control bus 226 and the supplementary control bus 228 define 

commands, and may fiirther identify the chips and/or banks to which the commands apply. 
The commands may be any set of commands for operation of the memory module 210. In 
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the present embodiment, the supplementary control bus 228 is used to provide a first selected 
subset of commands and the main control bus 226 to provide a second selected subset or, 
alternatively, the entire set of commands. For example, the supplementary control bus 228 
may be used for general commands, i.e., commands that relate to large blocks, of memory 
locations (like the entire module or an entire bank). The main control bus 226 handles 
location-specific commands, i.e., that relate to specific individual locations or groups of 
locations in the memory module 210, as weU as other commands in various embodiments. 
The memory location relating to the location-specific command may be indicated in any 
suitable manner, such as by signals on the address bus 224. Thus, the main control bus 226 
is used for commands usmg row and/or column information, typicaUy provided via the 
address bus 224, and the supplementary control bus 228 is used for commands that are not 
associated with row or column information, and thus do not utiUze the address bus 224. 

Command signals may be divided between the main/ control bus 226 and the 
supplementary control bus 228 in any suitable manner; simiTarly, the main control bus 226 
and the supplementary control bus 228 may be copfigured in any suitable manner to 
accommodate the command signals. For example/m one embodiment illustrated in Figure 
3, the main control bus 226 comprises a m^ command bus 410 having three main 
command bits (M-CMD), a main chip selej/bus bit 412 having one bit (M-CS), and a main 
bank selection bus 414 having two bits^-BA). The three main command bits are suitably 
designated as a row address strob/(RAS), a column address strobe (CAS), and a write 
enable (WE). In the present emjzfodiment, the main bank selection bus 222 comprises a two- 
bit bus which defines the bai^k to which a command is to be applied, and the one-bit main 
chip select bus 412 idenufies the relevant chip for the corresponding operation. 
[0028] Similarly, the supplementary control bus 228 may be configured in any suitable 

manner to accommodate the relevant command set. For example, the supplementary control 
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bus 228 suitably comprises a supplementary command bus 416 (S-CMD), a supplementary 
chip select bus 418 (S-CS), and a supplementary bank selection bus 420 (S-BA). In one 
embodiment, the supplementary control bus 228 solely faciUtates PRECHARGE operations. 
PRECHARGE operations may comprise operations to deactivate open rows in a particular 
bank or all banks of the memory, though the PRECHARGE operation may comprise any 
appropriate process for preparing a memory or portion of memory for access or restoring a 
memory to a selected state following an access. 
[§29] In the present dedicated PRECHARGE embodiment, the supplementary command 

5 

bus 416 is a one-bit signal such that assertion of the supplementary command bit signals the 
memory module 210 to execute a PRECHARGE command on the bank 3 lOA indicated by 
the supplementary chip select bus 418 and supplementary bank selection bus 420. 
Alternatively, because PRECHARGE is the only command controlled by the supplementary 
control bus 228, the supplementary command bus 416 may be omitted altogether, so that the 
supplementary chip select bus operates as the PRECHARGE signal. Activation of the 
supplementary chip select causes a PRECHARGE operation on the indicated chip in the 
bank designated by the supplementary bank selection bus 420. 

Thus, the ACTIVE and subsequent RfeAD or WRITE commands may be asserted 
using the main control bus 226 in conjiWtion with the address bus 224 to retrieve or store 
data. The next ACTIVE command/br other command may then be asserted via the main 
control bus 226 on another ba^ 310B concurrently with assertion of a PRECHARGE 
command on the original b^ 310A via the supplementary control bus 228. Accordingly, 
the PRECHARGE comofands may be asserted without using the main control bus 226, thus 
reUeving congestionA the main control bus 226 and tending to improve the performance of 
the memory modide 210. 
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[00311 More particularly, an electronic system 100 and method according to various aspects 

of the present invention may use the main control bus 226 to activate rows and select 
columns for memory access operations and the supplementary control bus 228 to close banks 
of memory. For example, referring to Figure 4, an initial memory access may be performed 
by identifying the relevant bank on the main bank selection bus 414, the relevant chip on the 
main chip select bus 412, and the relevant memory row on the address bus 224, and 
providing the ACTIVE signal on the main command bus 410 at a first time Tl. At 
g substantially the same time, the supplementary control bus 228 receives a NOP command to 

Si prevent any unwanted command from being registered on the supplementary control bus 

Q 228. 

[6>32] Following the initial memory access, a second memory access operation may be 

S initiated at a second memory location on a different bank. Accordingly, the second memory 

2 location may be identified on the main chip select bus 412, main bank select bus 414, and 

§ address bus 224, and the ACTIVE and READ or WRITE commands may be successively 

provided via the main command bus 410 attunes T3 and T4. Meanwhile, the supplementary 
control bus 228 may provide a PRECHARGE command to a previously accessed bank to 
close the stUl-active row firom the preceding memory access operation. For example, the 
previously accessed bank and chip are identified on the supplementary bank selection bus 
420 and supplementary chip select bus 418, respectively, at time T3. The PRECHARGE 
command is provided on the supplementary command bus 416 to initiate the precharge of 
the previously accessed bank while the second bank is being accessed via the main control 
bus 226. 

[00331 The command set may be apportioned and/or shared by the main control bus 226 and 

the supplementary control bus 228 in any suitable manner. For example, the commands may 
be shared such that all of the commands requiring the address bus 224 are asserted via the 
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main control bus 226, and aU of the commands that do not require the address bus 224 may 
be asserted via either the supplementary control bus 228 or the main control bus 226. Thus, 
the device providing the commands, such as the memory controller 212, may select which 
control bus 226, 228 on which to provide a command according to any selected criteria. 
Alternatively, the commands may be restricted to assertion on either the main control bus 
226 or the supplementary control bus 228, or the commands may be apportioned such that 
one set of commands is asserted only on the main control bus 226, a second set is asserted 
only on the supplementary control bus 228, while a third set may be asserted on either bus 
226, 228. 

Similarly, memory module interface 250, the main control bus 226, and the 
supplementary control bus 228 may be configured in any suitable manner to facUitate 
a assertion of the commands as apportioned or shared. In the embodiment in which all 

fl I 

H; commands not requiring the address bus 224 may be asserted on either the main control bus 

226 or the supplementary control bus 228, the respective control buses 226, 228 are suitably 
configured with sufficient bits to accommodate the relevant command set. For example, 
referring to Figure 5, the memory module 210 may accommodate nine commands such that 
three commands require the address bus 224 (such as ACTIVE, READ, and WRITE) and six 
commands do not (such as DESELECT, NO OPERATION, BURST TERMINATE, 
PRECHARGE, AUTO REFRESH, and LOAD MODE REGISTER). To accommodate all 
nine commands, the main control bus 226 may be configured with four command bits. 
Similarly, the supplementary control bus 228 is suitably configured with three command bits 
to accommodate the six commands that do not use the address bus 224. 
[0035] In alternative embodiments, the number of pins may be reduced by reconfiguring the 

command set and the main and supplementary command buses 226, 228 and the interface 
250. For example, the commands may be apportioned such that commands not requiring the 
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address bus 224 are asserted only on the supplementary control bus 228. Thus, in the 
present embodiment, the main control bus 226 may be configured to handle only three 
commands (ACTIVE, READ, and WRITE), requiring only two command bits, as illustrated 
in Figure 6. 

[0036] In another embodiment, the number of bits required by the supplementary control bus 

228 may be reduced by packetizing various commands. Packetizing comprises sending 
consecutive signals for a single command, such as for lower priority commands. For 
K example, referring to Figure 7, the supplementary control bus 228 may be configured with 

two supplementary command bits 416 as well as the supplementary chip select 418 and 
%f supplementary bank select bits 420. The supplementary command bits 416 may receive one 

of four main commands. Three commands are suitably executable commands, such as 
PRECHARGE, AUTO REFRESH, and NOP. The fourth command may be a secondary 
command indicator 620, referred to in this embodiment as EXTENDI. EXTENDI 
designates a secondary command 622 following, for example, in the next cycle. Thus, if 
EXTENDI is transmitted, the next cycle contains the secondary command 622. The 
secondary commands may comprise any appropriate commands, such as SELF REFRESH, 
WAKE, or LOAD MODE. In the present embodiment, the secondary commands comprise 
commands that are lower priority than the main commands. The main and secondary 
command sets may be selected, however, according to any desired criteria. 
[0037] Further, referring tO Figure 8, the secondary command 622 may indicate another 

command following, s\^h as in the next cycle, by asserting a tertiary command indicator 724 
(EXTEND2). Th^''^ tertiary command 726 may then be asserted in the following cycle. 
Additional command capability may be provided using additional sub-command indicators if 
desired. Thus, many low priority commands may be added without adding additional 
command/oits. 
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[0038] It should be appreciated that the particular implementations shown and described 

herein are illustrative of the invention and its best mode and are not intended to otherwise 
limit the scope of the present invention in any way. Indeed, for the sake of brevity, 
conventional signal processing, data transmission, and other functional aspects of the 
systems (and components of the individual operating components of the systems) may not be 
described in detail herein. Furthermore, the connecting lines shown in the various figures 
contained herein are intended to represent exemplary functional relationships and/or physical 
5 couplings between the various elements. It should be noted that many alternative or 

additional functional relationships or physical connections may be present in a practical 
^ communication system. 

(m39] The present invention has been described above with reference to a preferred 

S embodiment. However, those skilled in the art having read this disclosure will recognize 

ry 

that changes and modifications may be made to the preferred embodiment without departing 
^ from the scope of the present invention. These and other changes or modifications are 

intended to be uicluded within the scope of the present invention, as expressed in the 
following claims. 
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